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Description 

Field of the Invention 

5 The present invention relates, in general, to a digital computing system having a low power mode. More particularly, 

the invention relates to a digital computing system which prepares to enter a low power mode by broadcasting status 
information relating to the conditions for exit from the bw power mode. 

Background of the Invention 

10 

Digital computing systems, in particular integrated circuit computing systems, commonly have the ability to enter a 
low power mode during which time no processing is accomplished and various subsystems are shut down to reduce 
power consumption. It is common to provide that the occurrence of predetermined external events will "awaken" the 
system from its low power mode to resume normal processing. 

IS U.S. Patents 4,748,559 and 4,758,945, both assigned to the assignee of the present invention, disclose aspects of 

a digital computing system which responds to particular software instructions by entering one of two available low power 
modes. The described system is available as an integrated circuit designated the MCI 46805 from Motorola. Inc. of 
Austin. Texas. Either of the two available tow power modes disclosed can be terminated by a reset or interrupt event. 
In the case of interrupt events the mask bit, which prevents certain interrupts from being recognized by the system, must 

20 be cleared in order that a maskable interrupt event will terminate the low power mode. 

The above-mentioned patents describe a system which is well suited to traditional 'hand-packed' integrated circuit 
design methodology. However, as integrated circuit computing systems move toward 'modular' design methodologies 
in order to permit more rapid design of customized systems, some reset and Interrupt control circuits may be removed 
from close logical and physical proximity to the centra! processing unit. In this case, the previously known techniques 

2S for terminating a low power mode require modification. 

European Patent Application 0 050 844 describes a method of controlling a clock signal supplied to a logic circuit 
in a data processing apparatus so as to inhibit the supply of the clock signal to the logic circuit or to fix the level of the 
clock signal at a specific level in order to reduce power consumption. This patent application also teaches a clock signal 
supply inhibit instruction which, when read out. inhibits the supply of the clock signal to the logic circuit or fixes the level 

30 of the clock signal to a specific signal level. The clock signal is again supplied to the logk; circuit in response to the 
application of an interrupt signal." 

Summary of the Invention 

35 In accordance with a first aspect of the invention there is provided a digital computing system according to claim 1 . 

In accordance with a second aspect of the invention there is provided a method for executing an instruction in a 
digital computing system according to claim 7. 

Brief Description of the Drawings 

40 

One digital computing system utilizing the present invention will now be described, by way of example only, with 
reference to the accompanying drawings, in which: 

FIG. 1 is a block diagram of an integrated circuit digital computing system according to a particular embodiment of 
^ the present invention; 

FIG. 2 is a block diagram of the central processing unit of the computing system of FIG. 1; 
FIG. 3 illustrates the register set of the central processing unit of FIG. 2; and 

FIG. 4 is a timing diagram illustrating several bus cycles as executed by the central processing unit of FIG. 2. 

so Detailed Description of the Invention 

The terms "assert', 'assertion', 'negate' and "negation' will be used to avoid confusion when dealing with a mixture 
of "active high" and 'active low" signals. "Assert' and 'assertion' are used to indicate that a signal is rendered active, 
or logically true. "Negate" and "negation" are used to indicate that a signal is rendered inactive, or logically false. In 
55 addition, the terms 'set' and 'clear" will be used when referring to the rendering of a status bit or similar apparatus into 
its logically true or logically false state, respectively. 

FIG. 1 illustrates an integrated circuit computing system according to a particular embodiment of the present inven- 
tion. A microcomputer 10 comprises a central processing unit (CPU) 11 , an inter-module bus (1MB) 12, a serial commu- 
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nication interface 13, on-board memory 14. a timer module 15 and a system integration module (SIM) 16. Inter-module 
bus 12, which comprises multiple data, address and control signal lines as described in detail below, is coupled to and 
provides for communication between each of the other components of microcomputer 10. Serial interface 13 provides 
tor synchronous and/or asynchronous serial data transfer between microcomputer 10 and external devices and systems 
by means of several serial I/O pins. Memory 14 provides storage space for software instructions and other data useful 
to microcomputer 10. Timer module 15 provides various timing functions such as input capture, output compare and 
the like by means of several timer pins and is coupled to memory 14 by means of an interface 17. SIM 16 provides an 
interface between 1MB 12 and an external bus. the details of which are discussed below, and also provides certain 
system functions such as clock signal generation and distribution 

The tables which appear immediately below contain the signal definitions for all of the lines of 1MB 12 and the 
external bus which is coupled to SIM 16. Both of these buses are parallel communication buses. 
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TABLE I 
INTER-MODULE BUS SIGNALS 



SIGNAL 


MNE- 






fvl AMb 








Address Bus 


ADDRO- 
ADDR23 


24 bit address bus 


output 


Data Bus 


DATAO- 
DATA15 


16 bit data bus capable of 8 
and 16 bit transfers 


input/output 


Function Code 


FC0-FC2 


Identifies CPU stale 
(supervisor/ user) and 
address space of the 
current bus cycle 


output 


Clock 


CLOCK 


Master system clock 


input 


Cycle Start 


CYS 


Indicates start of internal 
buscyde 


output 


Address Strobe 


AS 


Indicates second phase of 
bus cycle and that address 
is valid 


output 


Data Strobe 


DS 


Indicates third phase of bus 
cycle and that data is valid 


output 


Read /Write 


WRITE 


Defines a bus cycle as a read 
or write, relative to the bus 
master 


output 


Transfer Size 


SIZO- 
SIZl 


Specifies the number of 
bytes yet to be transferred 
in a bus cycle 


output 


Data Transfer 
Acknowledge 


DTACK 


Slave response which 
terminates a bus cycle 


input 


Bus Error 


BERR 


Provides for termination of 
a bus cycle if no valid 
response is received 


input 


Relinquish and 
Retry 


RRT 


Provides a means for 
breakine a bus nustership 
standoff at the internal/ 
extendi bus boundary 


input 


Retry 


RETRY 


Provides for termination of a 
bus cycle which should 
be rerun 


input 

r 


Halt 


HALT 


Indicates that the CPU has 
halted due to an abnornul 
condition 


output 


Breakpoint 
Request 


BKPT 


Signals a request for a break 
point on the current bus cycle 


input 


Breakpoint 
Acknowledge 


FREEZE 


Indicates that the CPU has 
entered background 
debug nnode 


output 
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TABLE I (CONTD) 



System Reset 


SYSRST 


Provides a "soft * reset 
which does not disturb 
system configuration data 


output 


SIGNAL 
NAME 


MNE- 
MONIC 


FUNCTION 


DIRECTION 


Master Reset 


MSTRST 


Provides a "hard- 
reset of everyrthing 


input 


Interrupt 

Request 

Level 


IRQl - 1RQ7 


Prioritized interrupt 
requests to the CPU 


input 


Autovector 


AVEC 


Specifies that autovector 
feature is to be used during 


input 


Bus Request 


BRO - BRn 


Prioritized bus mastership 
arbitration signals 


input 


Bus Lock 


BLOCK 


Allows bus master to retain 
bus 


output 


Test Mode 


TSTMOD 


Enables test mode 
for all devices 


input 


Enable 1MB 
test lines 


IMBTEST 


Changes function of 
IR0MR07 to test lines 


input 



Note that signal directions in the table above are specified with respect to 
CPU 11. 

TABLE n 
EXTERNAL BUS SIGNALS 



SIGNAL 
NAME 


MNE- 
MONIC 


FUNCTION 


DIRECTION 


Address Bus 


A0-A23* 


24 bit address bus 


input/output 


Data Bus 


D0-D15 


16 bit data bus capable of 8 
and 16 bit transfers 


input/output 


Function Code 


FC0-FC2* 


Identifies CPU state 
(supervisor/ user) and 
address space of current bus 
cycle 


input/output 


Boot Chip 
Select 


CSBOOT 


Progranunable chip 
select forboot-uD 


output 


Bus Request 


BR^ 


Bus Mastership 
Reauest line 


input/output 


Bus Grant 


BG» 


Bus Mastership Grant Line 


output 


Bus Grant 
Acknowledge 


BGACK* 


Bus Mastership 

Grant Acknowledge line 


input/output 
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TABLE n (CONTD) 



Data and Size 
Acknowledge 


nsACKn - 

DSACKl 


Indicates that data is valid 
on read and that data has 

nAPn rAf*pit/fv4 on \A/Tift^ A1c/> 

I^ClZil ICVCIVCU WliiC* f\lo%J 

indicates port size. 


input/output 


Address Strobe 


AS 


Indicates that address, 

lUllLllUII Civ* ciitr VdllU 


output/input 


SIGNAL 

IN r\ IVl C 


MNE- 

IVi WIN 1^ 


FT TMPTTOM 




Data Strobe 


DS 


Indicates .that data is valid 
on write and that slave 
should drive data on read 


input /output 


Read /Write 


WRITE 


Defines a bus cycle as a read 
or write, relative to the bus 
master 


input/output 


Transfer Size 


SIZO- 
SIZl 


Indicates single or 
multi-byte transfer 


input/output 


Bus Error 


BERR 


Provides for termination of a 
bus cycle if no valid 
response is received 


input/output 


Halt 


HALT 


Indicates that the CPU has 
halted due to an abnormal 
condition 


input/output 


Interrupt 
Request , 

I pvpI 


IRQl - IRQ7 


Prioritized interrupt 
requests to 
the CPU 


input 


Autovector 


AVEC 


Specifies that autovector 

feature is to be used during 
an interrupt ack. cycle 


input/output 


Bus Lock 


BLCK 


Indicates indivisible 

bus cycles 


input/output 


Reset 


RESET 


System Reset 


inpml/output 


External 
System Clock 


CLK 


External system 
dock - bus clock 


outfnit 


Crystal Osc. 


EXTAL, 
XTAL 


Pins for connection of 
external oscillator 
or clock circuit 


input/output 


External 

r liter upacitor 


XFC 


Allows connection of an 
external niicr capaciior 
to internal clock circuit 


output 


Synthesizer 
Power Supply 


Vddsyn 


Provides power to internal 
clock synthesizer 


input 


Main Power 
Supply 


Vdd 


Provides power to chip 


input 


Freeze 


FRZ/QUC3T 


Acknowledges entry into 
background mode and outputs 
quotient bits in test mode 


output 



6 



EP 0 368 144 B1 





Test Mcxle 
Enable and In- 
state Control 


TSTME/TSC 


Enables test mode 
or causes output 
drivers to be tri-stated 


input 


5 


Qock Mode 
Select 


MODCK 


Selects source of 
system clock 


input 



The pins denoted above with an asterisk, the address pins A19-A23, the lunction code pins FC0-FC2. the bus 
request pin BR, the bus grant pin BG and the bus grant acknowledge pin BGACK, may also be used as programmable 

10 chip select pins. This feature of microcomputer 10 is not related to an understanding of the present invention. Signal 
directions are specified with respect to microcomputer 10. 

Among the functions of SIM 16 is that of determining when a bus cycle initiated by CPU 11 is directed to a device 
external to microcomputer 10. If this is the case. SIM 16 executes an appropriate bus cycle on the external bus and also 
mediates between the Internal bus cycle and the external bus cyde. In addition, SIM 16 Is capable of displaying internal 

IS bus cycles which are directed at modules internal to microcomputer 10 via the external bus. This feature is useful for 
debugging and development purposes, among others. 

FIG. 2 illustrates, In very simplified form, the internal structure of CPU 1 1 of FIG. 1 . Fundamentally, CPU 1 1 comprises 
a micro-machine 20. an execution unit 21, a set 22 of registers and a bus interface 23. Micro-machine 20 is coupled 
bi-directionally to interface 23 and to execution unit 21 . Registers 22 and execution unit 21 are coupled to one another 

20 by means of intemal buses and the like which are not illustrated here. Execution unit 21 is also bi-directionally coupled 
to Interface 23. Interface 23 is coupled to the address, data and control signals which comprise 1MB 12. 

Micro-machine 20 is responsible for determining the sequence in which Instructions are to be executed, receiving 
the instructions from interface 23 after they have been fetched from memory (either memory module 14 or external 
memory), instructing Interface 23 to perform Instruction fetches and operand read or write cycles and decoding instruc- 
ts tions into a plurality of control signals for use in controlling execution unit 21 . As a portion of the instruction sequencing 
function of micro-machine 20, it performs exception processing, including the function of determining whether to ac- 
knowledge Interrupt requests received via interface 23 from 1MB 12. Execution unit 22 is responsible lor the actual 
execution of the logical, arithmetic and other functions encoded in the Instructions received by micro-machine 20. Reg- 
isters 22 store various inputs to and results of the operations of execution unit 21 . 1MB interface 23 is a master-only 

30 interlace to 1MB 12. That is. it can initiate read and write cycles of 1MB 12, and It can permit another master to initiate 
such cycles, but it cannot respond to either a read or a write cycle of 1MB 12 which is initiated by another bus master. 

Referring now to FIG. 3, register 22 of FIG. 2 are illustrated in greater detail. Registers 22 comprise 8 32-bit data 
registers, designated D0-D7, 7 32-bit address registers, designated A0-A6, 2 stack pointers, designated USP (for user 
stack pointer) and SSP (for supervisor stack pointer), respectively, a single 32-bit program counter, designated PC. a 

35 single 16-bit status register, designated SR, 2 3-bit function code registers, designated SFC (for source function code) 
and DFC (for destination function code), respectively and a single 32-bit vector base register, designated VBR. The two 
stack pointers are alternately referred to with the designations A7 and A7', respectively 

Together, registers 22 comprise what is referred to as the programmer's model of CPU 1 1 . The programmer's model 
illustrated here will be familiar to any user of microprocessors of the 68000-family of microprocessors available from 

40 Motorola, Inc. of Austin Texas. 

For purposes of the present invention, only bits 8-10 of the status register SR are particularly relevant. These bits, 
designated 10, II and 12, respectively, comprise an interrupt mask. These three bits, which can encode 8 different interrupt 
mask settings, participate in the implementation of a prioritized interrupt recognition scheme. Basically, any interrupt 
source, whether internal or external, must identify its current interrupt priority level setting to CPU 11 in connection with 

45 its assertion of an Interrupt request. If a requesting interrupt source has a priority level setting higher than the current 
mask value encoded in bits 8-10 of the status register, then the interrupt will be recognized. If the priority value Is less 
than or equal to (except in the case of level 7 interrupts) the mask value, then the interrupt will not be recognized. Table 
III. below. Illustrates the Interrupt mask encoding scheme. 



TABLE III 



INTERRUPT MASK ENCODING 


MASK BITS 


MASKED INTERRUPT 


12 


11 


10 


PRIORITY LEVELS 


0 


0 


0 


none 



Continuation of the Table on the next page 
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TABLE III (continued) 



5 



10 



IS 



INTERRUPT MASK ENCODING 


MASK BITS 


MASKED INTERRUPT 


12 


12 


10 


PRIORITY LEVELS 


0 


0 


1 


0-1 


0 


1 


0 


0-2 


0 


1 


1 


0-3 


1 


0 


0 


0-4 


1 


0 


1 


0-5 


1 


1 


0 


0-6 


1 


1 


1 


0-6 



The priority level of an interrupt request Is deternnined by the levels of the seven interrupt request lines IRQ1 - 
IRQ7 . An interrupt source having a priority setting off 7 uses IRQ? to generate an interrupt request, a source with a 

20 setting of 6 uses IRQ6 to do so. and so forth. 

Under normal operating conditions, all interrupts requests are communicated to CPU 11. Interrupt logic internal to 
CPU 11 compares the priority level of each Interrupt request to its current mask setting and. if appropriate, commences 
an exception processing sequence. 

The normal read and write cycles of 1MB 12 will be described with reference to FIG. 4, which is a timing diagram 

25 illustrating those cycles. The signals illustrated are those of 1MB 12. The cycles defined for the external bus are funda- 
mentally similar to those described. The basic internal read and write cycles of 1MB 12 {i.e.. cycles directed to one of 
the internal modules of microcomputer 10) each take place over the span of two complete cydes of CLOCK, the master 
system dock signal. The four phases, or tics, of CLOCK which occur during the basic bus cycles are numbered 1 -4 and 
correspond to four states of the bus cycles. 

30 An internal read cycle begins with the assertion of CYS during state 4. The bus master also drives the a ddress and 

function code lines at this time, as well as negating WRITE . During this period. 1MB 12 Is precharging AS , AACK and 
□TACK . 

During the next clock phase, state 1, the bus master asserts and the slave which is to respond to this cycle 
asserts AACK . Also, 1MB 12 precharges the data lines and DS during state 1. 
35 At the beginning of state 2. the bus master asserts 5§ . The slave may begin driving the data lines as early as the 

beginning of state 2. 

The slave should respond to the bus cycle by asserting DTACK or an appropriate error signal during state 3. The 
master samples DTACK and the error signals at the end of state 3 and, If neither is asserted, the master inserts a wait 

state (referred to as 3*), then returns to state 3 to sample DTACK and the error signals again. 

40 By the beginning of state 4, the slave must have begun driving the data lines and stops asserting DTACK . This 

completes the basic internal read cyde. 

The basic internal write cycle is very similar to the cycle described above except that WRITE is asserted in state 4 
and that the bus master drives the data beginning in state 2. Otherwise, the write cycle Is Identical to the read cyde. 
The basic external read and write cydes are fundamentally the same as the corresponding intemal cycles but for 
45 the insertion of wait states (state 3*) In each cycle. This Insertion Is performed by SIM 1 6 to "hold off" the termination of 
the 1MB cycle while the slower, external bus completes its cyde. The external bus has a five state basic cycle 

A low power mode is defined for microcomputer 10 which is initiated by the execution of a particular instruction, 
LPSTOP, by CPU 1 1 . This instruction comprises three words (a total of 48 bits). The first two words contain the particular 
bits which Identify the LPSTOP instruction (the opcode) and the third word contains immediate data. When the LPSTOP 
so instruction is received and decoded by micro-machine 20 (FIG. 2), a number of control signals are produced which 
cause execution unit 21 and bus interface 23 to perform certain tasks. First, one or more control signals are produced 
which cause execution unit 21 to place the immediate data portion of the LPSTOP instruction into the status register 
SR. This has the effect of resetting the interrupt mask bits (along with the other control and condition code bits in the 
. status register) to the values specified In the immediate data field. Next, one or more control signals are produced which 
55 cause the program counter to be Incremented so as to point to the location off the next instruction to be fetched. Finally, 
one or more control signals are produced which cause bus interface 23 to execute a special bus cycle, the LPSTOP cyde. 

The LPSTOP cycle is fundamentally a normal, internal write cycle as is described above. The LPSTOP cycle is 
Identified as different from other write cycles by the values of the function code signals (FC0-FC2) and of certain of the 
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address signals (A1 6-A1 9). 

The lunclion code signals identify each read or write cycle initiated by CPU 1 1 as being addressed to one of several 
possible address spaces. The various address spaces and function code signal encodings are set forth in Table IV. 

5 TABLE IV 



10 



15 



FUNCTION CODE ASSIGNMENTS 


FC2 


FC_1 


FCO 


ADDRESS SPACE 


0 


0 


0 


UNDEFINED 


0 


0 


1 


USER DATA 


0 


1 


0 


USER PROGRAM 


0 


1 


1 


UNDEFINED 


1 


0 


0 


UNDEFINED 


1 


0 


1 


SUPERVISOR DATA 


1 


1 


0 


SUPERVISOR 








PROGRAM 


1 


1 


1 


CPU 



20 For an LPSTOP cycle the function code signals are all equal to one, making it a CPU space cycle. There are several 

other CPU space cycles (breakpoint and interrupt acknowledge, for example), so address lines A16-A19 are used to 
distinguish the CPU space cycles from one another. For the LPSTOP cyde, A19 and AIB are equal to 0 and A16 and 
A17are equal to 1. 

The LPSTOP cyde is one example of a special register access cycle. All special register access cycles have the 
25 function code and A1 6-A1 9 encodings described atDOve. The lower sixteen address signals specify which special register 
is being accessed. In the preferred embodiment, the only special register implemented is the interrupt mask register in 
SIM 16, which is the destination of the LPSTOP cycle. In the general case, address signals A12-A15 identify the chip, 
signals A8-A11 identify the module and A0-A7 identify the special register which is the target of the special register 
access cycle. In the preferred embodiment, signals A0-A15 are all equal to 1 for the LPSTOP cyde. 
30 The lower three lines of the data bus (DATA0-DATA2) are used to communicate bits 8-10 of the status register 

(10-12) during the LPSTOP cycle. SIM 1 6 responds to the LPSTOP cycle by storing the interrupt mask bits in its interrupt 
mask register 

The LPSTOP cycle is intended primarily to notify internal modules that low power mode entry is imminent and to 
communicate the interrupt mask bits to SIM 16. However, it is possible that devices external to microcomputer 10 may 

^5 also need to be notified of the coming low power mode. Therefore, if the external bus is not under the control of an 
external bus master when the LPSTOP cycle is executed, the LPSTOP cycle will be executed on the external bus by 
SIM 16. so that external devices can prepare, if necessary, for the low power mode. 

In addition to storing the interrupt mask bits, SIM 16 responds to the LPSTOP cycle by halting the 1MB clock signal, 
CLOCK. CPU 11 and all of the other internal modules of microcomputer 10 use CLOCK as the sole source of fundamental 

^0 internal timing. Thus, when CLOCK is halted, all of these modules are also halted. This greatly reduces power consump- 
tion. SIM 16 continues to generate clock signals for its own use. and so remains "awake" during the low power mode. 
The externally-supplied dock signal. CLK, may or may not be halted during the low power mode, depending on the state 

of a control bit which is set within SIM 1 6 under control of CPU 1 1 . 

Events which can terminate the low power mode are resets (an external device holding the RESET pin low for a 

^ predetermined period of time) and interrupts which have a priority level sufficiently high not to be masked by the interrupt 
mask bits stored in the interrupt mask register of SIM 16. Since all of the internal modules other than SIM 16 are shut 
down during the low power mode, none of them can produce an interrupt signal to terminate the low power condition. 
However, since SIM 16 itself contains certain monitors {e.g.: watchdog timers, periodic interrupt circuits and the like) 
which are capable of generating interrupts, and since SIM 16 remains active during the low power mode, the interrupt 

^ which terminates the power down condition can arise within microcomputer 10. In the particular embodiment being 
described, of the interrupt sources within SIM 16, only the periodic interrupt circuit remains active during the low power 
mode. Of course, it is also possible that an external circuit will be the source of the interrupt. 

During the low power mode of operation. SIM 16 simply awaits either a reset or interrupt event. Any reset event 
causes SIM 16 to resume the generation of the CLOCK signal and to assert the MSRST signal, thus resuming normal 

55 program execution. Any interrupt event which has a sufficiently high priority to exceed the level masked by the interrupt 
mask bits passed to SIM 16 by the LPSTOP cycle will also cause an exit from the low power mode. In t he ca se of an 
interrupt, SIM 16 will resume generating CLOCK and also present the interrupt request to CPU 11 on the IRQ1 - 1RQ7 
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lines of 1MB 1 2. CPU 1 1 will respond to this interrupt request as it would to any other such request, will execute appropriate 
exception processing routines and will return to normal program execution with the instruction which follows the LPSTOP 
instruction which initiated the low power mode. 

Other than during the power down condition which follows the execution of the LPSTOP instruction, the interrupt 
5 mask register within SIM 16 is ignored. All internally generated interrupts are passed directly to CPU 11 via 1MB 12 
CPU 11 performs the comparison necessary to a determination of whether the interrupt signal will be acknowledged. 
All externally generated interrupts are passed by SIM 16 directly from the external bus interrupt lines to those of tMB 
12 unconditionally. 

The separation of the low power mode termination logic from the normal reset and Interrupt logic in the CPU permits 

10 the CPU to be completely shut down during the low power mode, thus saving considerable power. Allowing the System 
Integration Module to perform the mask level comparison independently permits low priority interrupts to be completely 
ignored, obviating the need to 'awaken" the CPU to perform the comparison. The present invention is not limited to the 
situation in which an interrupt mask setting is the critical determinant of exit from the power down mode. It may be some 
other conditional evaluation which the central processing unit would normally make, but which is advantageously made 

15 elsewhere in the system during a low power mode of operation. In addition, the details of the LPSTOP cycle described 
are not critical to the functioning of the invention. Any means of communicating the conditions by which exit from the 
low power mode is qualified from the central processing unit to some portion of the system which will remain active 
during the power down condition may be substituted for the disclosed LPSTOP bus cycle. 

While the present invention has been shown and described with reference to a particular embodiment thereof, those 

20 skilled in the art will recognize various modifications. For instance, while the invention is disclosed in the context of a 
microcomputer comprising certain modules, any of these modules might be replaced by other modules having different 
functionality. In addition, although the central processing unit of the preferred invention is a microcoded machine, the 
invention might readily be implemented in the context of a hard-wired machine. Furthermore, the particular embodiment 
described implements the cessation of clock signals by halting the production of those signals at their source. An alternate 

25 implementation would be to continue to produce and distribute a clock signal during the low power mode and also to 
produce an LPSTOP control signal which would be distributed to all internal modules. At each module, logic would 
respond to the LPSTOP control signal by either blocking the clock signals, thus shutting down the module, or not blocking 
the clock signals, thus allowing the module to continue operation during the low power mode. This alternate embodiment 
would entail increased power dissipation during the low power mode, but would provide increased flexibility by allowing 

30 some modules to continue operation during the low power mode. 



Claims 

35 1 . A digital computing system (1 0) comprising an inter-module communication bus (12); 

a central processing unit (11) comprising: 

register means (22) for storing an Interrupt nnask; 
40 a bus controller (23) coupled to the inler-module communication bus (12); 

first interrupt means (20) for selectively responding to an interrupt request received via the bus controller 
(23) from the inter-module communication bus(12) dependent on a comparison between a priority level of 
the interrupt request and the interrupt mask; and 
execution means (21) for executing instructions; and 

45 

an Integration module (16) coupled to the inter-module communication bus (12) comprising: 

clock signal generation means (16) for providing, via the inter-module communication bus (12), a clock 
signal to the central processing unit; 

50 

characterized in that: 

the execution means is responsive to a particular instruction by causing the bus controller (23) to place prede- 
termined signals and the interrupt mask on the inter-module communication bus (12), and 
the clock signal generation means ceases to provide the clock signal to the central processing unit in response 
55 to the receipt of the predetermined signals and interrupt mask from the inter-module communication bus (12). 

2. A digital computing system (10) according to claim 1 further comprising: 
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first logic means (16) coupled to the communication bus for storing the signals representing the interrupt mask: 
second logic means (16) coupled to the first logic means and being active only it the clock signal generation 
logic is not providing the clock signal to the central processing unit for responding to an interrupt request signal 
by comparing a priority level of the interrupt request signal to the contents of the first logic means (16): 
third logic means (16) for selectively causing the clock signal generation logic to resume providing the clock 
signal to the central processing unit dependent on a result of the comparison performed by the second logic 
means; and 

the clock signal generation logic continuously providing a clock signal to the first, second and third logic means. 

3. A digital computing system according to claim 1 or 2 further characterized in that 

the execution means (21) further responds to the particular one of the instructions by storing in the register 
means (22) an immediate bit field of the particular one of the instructions. 

4. A digital computing system (10) according to claim 1 further comprising: 

interrupt mask means ( 1 6) for storing, in response to the receipt of the predetermined signals from the inter-mod- 
ule communication bus (12), the interrupt mask; 

second interrupt means (16) for selectively responding to an interrupt request dependent on a comparison 
between a priority level of the interrupt request and the interrupt mask stored in the interrupt mask means (16): 
and 

the clock signal generation means (16) being responsive to the second interrupt means to resume providing 
the clock signal to the central processing unit. 

5. A digital computing system (10) according to any preceding claim further comprising: 

means (16) for coupling the system to an external bus. said means for coupling being responsive to receipt of 
the predetermined signals and Interrupt mask to place the predetermined signals and the interrupt mask on the 
external bus. 

6. A digital computing system (10) according to any preceding claim wherein the digit3l computing system is formed 
on an integrated circuit. 

7. A method for executing a particular instruction in a digital computing system (10), wherein the system (10) has a 
central processing unit (11) and an integration module (16) which are coupled by way of an inter-module commu- 
nication bus (12), the central processing unit (11) having a storage circuit (22) for storing an interrupt mask value, 
the method comprising the steps of: 

the central processing unit (11) receiving the particular instructk>n; 
the central processing unit (11 ) decoding the particular instruction; and 

the central processing unit (11 ) initiating a write bus cycle during execution of the particular instruction; 
the method being characterized by the steps of: 

transferring the interrupt mask value and predetermined signals from the central processing unit (11) to the 
integration module (16) by way of the Inter-module communication bus (12) during the write bus cycle; and 
the integration module (16) halting provision of clock signals to the central processing unit (1 1 ) in response to 
receiving the interrupt mask value and the predetermined signals from the communication bus (12). 

8. A method according to claim 7 further comprising the step of: storing the interrupt mask value in a register in the 
integration module (16). 

9. A method according to claim 7 or 8 further comprising the steps of: 

receiving an interrupt request signal having a priority level; 

comparing the priority level to the interrupt mask value in order to produce a comparison result; and 
selectively resuming provision of the clock signals to the central processing unit (11 ) dependent upon the com- 
parison result. 

1 0. A method according to claim 7, 8 or 9 wherein the particular instruction has a mnemonic representation of "LPSTOP*. 



11 



EP 0 368 144 B1 



Patentanspruche 

1. Ein digitales Rechnersystenn (10) umfassend einen Zwischen-Modulkommunikationsbus (12): eine zentrale Verar- 
beitungseinheit (11) umfassend: 

eine Registereinrichtung (22) zum Speichem einer Unterbrechungsmaske; 

eine Bussteuerungseinrichtung (23), die mit dem Zwischen-Modulkommunikationsbus (12) gekoppelt ist; 

eine erste Unterbrechungseinrichtung (20) zum selektiven Reagieren auf eine Unterbrechungsanforderung. 
die uberdie Bussteuerungseinrichtung (23) von dem Zwischen-Modulkommunikationsbus (12) in Abhandlgkeit 
von einem Vergleich zwischen einem Prior itatsniveau .der Unterbrechungsanforderung und der Unterbre- 
chungsmaske erhalten worden ist; und 

eine Ausfuhrungseinrichtung (21 ) zum Ausfuhren von Befehlen; und 

ein Integrationsmodul (16), der mit dem Zwischen- Modulkommunikationsbus (12) gekoppelt ist und umfa3t: 

eine Taktsignal-Erzeugungseinrichtung (15) zum Bereitstellen eines Taktsignals f Or die zentrale Bearbeitungs- 
einheit uber den Zwischen-Modulkommunikationsbus (17) 

dadurch gekennzeichnet, da3 

die Ausfuhrungseinrichtung auf einen bestimmten Befehl reagiert, indem die Bussteuerungseinrichtung (23) 
veranlaBt wird. vorbestimmte Signale und die Unterbrechungsmaske aut den Zwischen-Modulkommunikati- 
onsbus (12) zu geben, und 

die Taktsignal-Erzeugungseinrichtung aufhort, das Taktslgnal an die zentrale Verarbeitungseinheit in Reaktion 
auf den Empfang der vorbestimmten Signale und der Unterbrechungsmaske von dem Zwischen-Modulkom- 
munikationsbus (12) zu liefem. 

2. Ein digitales Rechnersystem (10) gema3 Anspruch 1 , da3 femer umfa3t: 

eine erste logische Einrlchtung (10), die mit dem Kommunikationsbus zum Speichern der Signale gekoppelt 
ist. die die Unterbrechungsmaske darstellen; 

eine zweite, logische Einrichtung (16). die mit der ersten. logischen Einrichtung gekoppelt und nur aktiv ist, 
wenn die Taktsignal-Erzeugungslogik kein Taktsignal an die zentrale Verarbeitungseinheit zum Reagieren auf 
ein Unterbrechungsanforderungssignal lieferl. indem ein Prioritatsniveau des Unterbrechungsanforderungssi- 
gnals mil den Inhalten der ersten, logischen Einrichtung (16) verglichen wird. 

eine dritte, logische Einrichtung (16).um selektiv zu bewirken. daB die Taktsignal-Erzeugungslogik das Bereit- 
stellen des Taktsignals fur die zentrale Verarbeitungseinheit in Abhangigkeit von einem Ergebnisdes Vergleichs 
wieder aufnimmt, der durch die zweite, logische Einrichtung ausgefOhrt worden ist; und 

eine Taktsignal-Erzeugungslogik, die fortlaufend ein Taktsignal an die erste, zweite und dritte, logische Einrich- 
tung liefert. 

3. Ein digitales Rechnersystem gemaQ Anspruch 1 Oder 2, ferner dadurch gekennzeichnet, daB 

die Ausfuhrungseinrichtung (21) ferner auf den Bestimmten der Befehle reagiert, indem in der Registereinrich- 
tung (22) ein unmittelbares Bitteld des bestimmten der Befehle gespeichert wird. 

4. Ein digitales Rechnersystem (10) gemaB Anspruch 1 , das femer umfaBt: 

eine Unterbrechungsmaskeneinrichtung (16) zum Speichern der Unterbrechungsmaske in Reaktion auf das 
Empfangen der vorbestimmten Signale von dem Zwischen-Modulkommunikationsbus (12); 
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eine zweite Unterbrechungseinrichlung (16) zum selekliven Reagieren aul eine Unierbrechungsanloraerung 
in Abhangigkeil von einem Vergleich zwischen einem Priorilatsniveau der Unterbrechungsanforderung und der 
Unterbrechungsmaske, die in der Unterbrechungsmaskeneinrichtung (16) gespeichert ist; und 

die Taktsignal-Erzeugungseinrichtung (16) auf die zweite Unterbrechungseinrichlung reagierl, urn das Bereil- 
stelten des Taktsignals fur die zentrale Verarbeitungseinheit wieder aufzunehmen. 

5. Ein digitales Rechnersystem (10) gemaQ irgendeinem vorhergehenden Anspruch, ferner umfassend: 

eine Einrichtung (16) zum Koppein des Systems mit einem externen Bus, wobei die genannte Kopplungsein- 
richtung auf das Erhalten der vorbestimmten Signale und der Unterbrechungsnnaske reagiert, urn die vorbe- 
stimmten Signale und die Unterbrechungsmaske auf den extemen Bus zu geben. 

6. Ein digitales Rechnersystem (16) gemaB irgendeinem vorhergehenden Anspruch, wobei das digitaie Rechnersy- 
stem auf einer integrierten Schaltung gebildet ist. 

7. Verfahren zum Ausfuhren eines bestimmten Befehls in einem digitalen Rechnersystem (10). wobei das System 
(10) eine zentrale Verarbeitungseinheit (11) und einem Integrationsmodul (16) hat, die uber einen Zwischen-Modul- 

kommunikationsbus (12) gekoppelt sind. die zentrale Verarbeitungseinheit (11) eine Speicherschaltung (22) zum 
Speichern eines Unterbrechungsmaskenwertes aufweisl, das Verfahren die Schhtte umfa3t: 

die zentrale Verarbeitungseinheit (11) erhalt den bestimmten Befehl; 

die zentrale Verarbeitungseinheit (11) dekodiert den bestimmten Befehl; und 

die zentrale Verarbeitungseinheit (11) initiiert einen Schreib-Buszyklus wahrend der Ausfuhrung des bestimm- 
ten Befehls; 

wobei das Verfahren durch die Schhtte gekennzelchnet Ist: 

Ubertragen des Unterbrechungsmaskenwertes und der vorbestimmten Signale von der zentralen Verarbei- 
tungseinheit (11) zu dem Integrationsmodul (16) mittels des Zwischen-Modulkommunikationsbusses (12) wah- 
rend des Schreib-Buszyklus; und 

der Integrationsmodul (16) halt das Bereitstellen von Taktsignalen fOr die zentrale Verarbeitungseinheit (11) in 
Reaktion auf das Erhalten des Unterbrechungsmaskenwertes und der vorbestimmten Signale von dem Kom- 
munikationsbus (12) an. 

8. Ein Verfahren gema3 Anspruch 7, das femer den Schritt umfa3t: 

Speichern des Unterbrechungsmaskenwertes in einem Register in dem Integrationsmodul (16). 

9. Ein Verfahren gemalB Anspruch 7 Oder 8, das ferner die Schritte umfa3t: 

Erhalten eines Unterbrechungsanforderungssignals, das ein Prioritatsniveau hat; 

Vergleichen des Prioritatsnlveaus mit dem Unterbrechungsmaskenwert, um ein Vergleichsergebnis zu erzeu- 
gen; und 

selektives Wiederaufnehmen der Bereitstellung von Taktsignalen fur die zentrale Verarbeitungseinheit (11) in 
Abhandigkert von dem Vergleichsergebnis. 

10. Ein Verfahren gemafJ Anspruch 7, 8 Oder 9, wobei der bestimmte Befehl eine mnemonische Darslellung von 
•LPSTOP" ist. 
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Revendications 

1 . Systeme de traitement numerique ( 1 0) comprenant un bus de communications intemnodules ( 1 2): 

une unitd centrale de traitement (11 ) comprenant: 

5 

• des moyens de registre (22) pour mdmoriser un masque d'interruption; 

* un regisseur (ou 'contr6leur*) de bus (23) connects au bus de communications intermodules (12); 

des premiers moyens d'interruption (30) pour r^pondre s^lectivement ^ une demande d'interruption re^ue par 
Tintermediaire du regisseur de bus (23) en provenance du bus de communications intermodules (12) selon ie 
10 resultat d'une comparaison entre un niveau de priorite de la demande d'interruption et Ie masque d'interruption; 

des nnoyens d'exdcution (21) pour ex^cuter les Instructions; et 

un module d'intdgration (16) connects au bus de communications intermodules (12), comprenant: 

des moyens de generation de signal d'horloge (1 6) pour fournir. par I'intermediaire du bus de communications 

intermodules (12). un signal d'horloge k I'unit^ centrale de traitement. 

IS caracterise en ce que: 

les moyens d'execution sont sensibles d une instruction precise en amenant Ie regisseur de bus (23) a placer 
des signaux predetermines et ie masque d'interruption sur le bus de communications intermodules (12); et 
les moyens de generation de signal d'horloge cessent de fournir le signal d'horloge ^ I'unite centrale de traite- 
ment en reponse a la reception des signaux predetermines et du masque d'interruption issus du bus de com- 

20 munlcations intermodules (12). 

2. Systeme de traitement numerique (10) selon la revendication 1, comprenant en outre: 

des premiers moyens de logique (16) connectes au bus de communications intermodules pour memoriser les 
signaux representant le masque d'interruption; 

des deuxiemes moyens de logique (16) connectes aux premiers moyens de logique et etant actifs uniquement 
si la logique de generation de signal d'horloge n'est pas en train de fournir le signal d'horloge ^ Tunite centrale 
de traitement pour repondre d un signal de demande d'interruption en comparant un niveau de priorite du signal 
de demande d'interruption au contenu des premiers moyens de logique (16); 

des troisiemes moyens de logique ( 1 6) pour amener selectivement la logique de generation de signal d'horloge 
^ reprendre la fourniture du signal d'horloge k I'unite centrale de traitement selon le resultat de la comparaison 
eftectuee par les deuxiemes moyens de logique; et 

la logique de generation de signal d'horloge foumit en permanence un signal d'horloge aux premiers, deuxiemes 
et troisiemes moyens de logique. 

3. Systeme de traitement numerique selon ta revendication 1 ou 2, caracterise en outre en ce que: 

les moyens d'execution (21 ) repondent en outre k une Instruction precise parmi les instructions en memorisant 
dans les moyens de registre (22) un champ de binaires immediat de la une Instruction precise. 

40 

4. Systeme de traitement numerique (10) selon la revendication i , comprenant en outre: 
des moyens de masque d'interruption (16) pour memoriser. en reponse a la reception des signaux predeter- 
mines Issus du bus de communications intermodules (12). ie masque d'interruption: 

. des deuxiemes moyens d'interruption (1 6) pour repondre selectivement k une demande d'interruption selon le 
resultat d'une comparaison entre un niveau de priorite de la demande d'interruption et le masque d'interruption 
memorise dans les moyens de masque d'interruption (16); et 

les nrwyens de generation de signal d'horloge etant sensibles aux deuxiemes moyens d'interruption pour re- 
commencer de fournir le signal d'horloge d I'unite centrale de traitement. 

5. Systeme de traitement numerique (10) selon I'une quelconque des revendications pr6c6dentes, comprenant en 

outre: 

des moyens (16) pour connecter le systeme k un bus exterieur, lesdits moyens pour connecter etant sensibles 
55 e la reception des signaux predetermines et du masque d'interruption pour placer les signaux predetermines 

et le masque d'interruption sur le bus exterieur. 

6. Systeme de traitement numerique (10) selon I'une quelconque des revendications precedentes, dans tequet le 
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systeme de traitement numerique est formd sur un circuit intdgre. 

7, Precede pour executer une instruction precise dans un syst6me de traitement numerique (10), dans lequel le sys- 
teme (10) a une unit6 centrale de traitement (11) et un module d'int^gration (16) qui sent connect6s au moyen d'un 
5 bus de comunicattons intermodules (12), I'unitd centrale de traitement (11) ayant un circuit de memorisation (22) 

pour mdmorlser une valeur de masque d'Interruption, le procddd comprenant les 6tapes dans lesquelles: 

runit6 centrale de traitement (11) revolt I'instruction precise; 

I'unite centrale de traitement (11 ) decode I'instruction precise; et 
10 - Tunite centrale de traitement (11) declenche un cycle d'ecriture du bus pendant i'execution de I'instruction pre- 

cise. 

le procede etant caracterise par les etapes consistant a: 
transferer la valeur de masque d'interruption et des signaux predetermines de I'unite centrale de traitement 
(11) au module d'integration (16) au moyen du bus de communications intermodules (12) pendant ie cycle 
IS d'ecriture du bus; et 

le module d'integration (16) cessant de foumir les signaux d'horloge k {'unite centrale de traitement (11) en 
reponse k la reception de la valeur de masque d'interruption et des signaux predetermines issus du bus de 
communications intermodules (12). 

20 8. Procede selon la revendication 7, comprenant en outre I'etape consistant a; 

memoriser la valeur de masque d'interruption dans un registre du module d'integration (16). 

9. Procede selon la revendication 7 ou 8, comprenant les etapes consistant k: 

2S 

recevoir un signal de demande d'interruption ayant un niveau de priorite; 

comparer le niveau de priorite k la valeur de masque d'interruption afin de produire un resultat de comparaison; 
et 

reprendre seiectivement la foumlture des signaux d'horloge k I'unite centrale de traitement (1 1 ) selon ie resultat 
30 de la comparaison. 

10. Procede selon la revendication 7. Sou 9, dans lequel I'instruction precise a la representation mnemonique "LPSTOP" 
pour decodage par ladite unite centrale de traitement (11). 
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